-
-
Notifications
You must be signed in to change notification settings - Fork 248
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Linux c++ support using musl-cross-make toolchains #231
Conversation
I will see to fix pgsql compilation and add imap back once this is merged, so it doesn't become a giant PR again. No point creating a PR doing these things now and changing them later when this is merged. |
Is there any difference between |
Some libraries build into /lib64 for me. Edit: I just realised we're using cmake to build them. We can specific the dir to /lib with -DCMAKE_INSTALL_LIBDIR (or however it was called). I'll undo the pkgconfig commit and change the libdir instead. |
e06bab3
to
a90cc14
Compare
I'm split on the decision whether to add musl to PATH, or to treat it as a library and specify absolute paths when we specify cc/cxx/ld/ar. What do you think? Of course adding it to PATH is easier when the user wants to use the tools outside of spc too, but by specify full path we don't rely on the users environment and/or don't have to change it. What do you think? @crazywhalecc $arch = arch2gnu(php_uname('m'));
$this->setOptionIfNotExist('cc', "{$arch}-linux-musl-gcc");
$this->setOptionIfNotExist('cxx', "{$arch}-linux-musl-g++");
$this->setOptionIfNotExist('ar', "{$arch}-linux-musl-ar");
$this->setOptionIfNotExist('ld', "{$arch}-linux-musl-ld");
$this->setOptionIfNotExist('library_path', "LIBRARY_PATH=/usr/local/musl/{$arch}-linux-musl/lib");
$this->setOptionIfNotExist('ld_library_path', "LD_LIBRARY_PATH=/usr/local/musl/{$arch}-linux-musl/lib"); becomes $arch = arch2gnu(php_uname('m'));
$path = SOURCE_PATH . "/musl-cross-make/{$arch}";
$this->setOptionIfNotExist('cc', "{$path}/bin/{$arch}-linux-musl-gcc");
$this->setOptionIfNotExist('cxx', "{$path}/bin/{$arch}-linux-musl-g++");
$this->setOptionIfNotExist('ar', "{$path}/bin/{$arch}-linux-musl-ar");
$this->setOptionIfNotExist('ld', "{$path}/bin/{$arch}/{$arch}-linux-musl/bin/ld.gold");
$this->setOptionIfNotExist('library_path', "LIBRARY_PATH={$path}/{$arch}-linux-musl/lib");
$this->setOptionIfNotExist('ld_library_path', "LD_LIBRARY_PATH={$path}/{$arch}-linux-musl}/lib"); |
In the past, I have tried to avoid compiling the toolchains necessary for the compilation itself in user mode. Because whether you use a downloaded binary and add it to PATH, or manually compile a gcc, they will consume a lot of time and disk space and it is intolerable. Using package management can speed things up, especially in Alpine environments where they can be installed directly. However, if musl-cross-make is stable and feasible now, we could add this pre-dependent library when detecting non-Alpine environments, which will only extend the time for compiling PHP in these distributions. At this time it is more appropriate to become the latter, but we also need to consider compatibility with other libraries (so this will be another big project) |
But anyway, I don't want to make this very complicated. Maybe it would be cool to support purely static compilation for glibc-based distributions, but I don't want to have to make extensive changes to every library that already implements the compilation command. The final impact on the compiler is best implemented only in |
I don't plan to have everyone compile musl-cross-make themselves, downloading the archive you see in MuslFix takes like 5 seconds. And it doesn't happen on Alpine, only on glibc based distros. The install command you see is only for the musl-wrapper (which is needed so that compiler tests that compile dynamically work). It only takes about 15 seconds for me, 30 seconds on a 4 core ARM VM.
Most of the individual lib changes are actually fixes for alpine too and not limited to glibc distros. It's about being able to compile different extensions together without running into compilation/linking failures. It just makes sense to fix them with this branch because why add half-broken c++ support like we currently have it on alpine when with minimal extra changes we can directly get other combinations working too. The only glibc specific necessary changes are specifying |
…ay in extra_libs)
…ome libs require it to load -lstdc++)
I successfully built the C++ extension on Debian using I will do some updates tomorrow:
And you are right, it is unrealistic to build musl-toolchain using actions, maybe we just keep this Dockerfile and config.mak file for future modification. |
I do not like this. It's more to maintain for us (musl-gcc wrapper AND $arch-linux-musl).
Bad idea, we have no control over which musl-gcc wrapper version it will install and if our $arch-linux-musl is compatible with it. Musl tries to be future compatible, but it's hard to guarantee it.
Good idea!
I built it no problem on a 4 core 16 gig ram aarch64 azure VM with Alma and Alpine. The RAM requirement seems to only be true for Docker compilation. Exact model: |
I'm not sure if this is correct, please revert if it doesn't fix the issue
For compiling imagemagick under the macOS platform, I found a strange point: if I do not use the |
Hmm, I can't test MacOS compilation, sorry :( |
That's okay. I will figure it out.
发自我的 iPhone
在 2023年10月30日,03:12,DubbleClick ***@***.***> 写道:
Hmm, I can't test MacOS compilation, sorry :(
—
Reply to this email directly, view it on GitHub<#231 (comment)>, or unsubscribe<https://github.com/notifications/unsubscribe-auth/AE3DTPDVOX3S5PICYDZGCMTYB2L75AVCNFSM6AAAAAA6CDOWTSVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTOOBUGIYDANJUHA>.
You are receiving this because you were mentioned.Message ID: ***@***.***>
|
I've tested the common extensions on Linux x86_64, as well as the compilation results of icu, imagemagick, postgresql, and ldap in cross-make. At the moment, all of these seem to be working well, and it's time to merge it. 🎉 There are really a lot of changes in this pull request, and I can't possibly test all the combinations of extensions in a short period of time. Additionally, there are two new issues and PRs will be created:
|
make it rc-8, I still want to add imap support after this for 2.0 release! |
This PR will
closes #148
closes #212
closes #217
closes #234
closes #94
Tasks